

And the state of t

## **CLAIMS**

1. Apparatus for processing data, said apparatus comprising:

a data processing register operable to store a data value;

a register writing circuit operable to store a data value to said data processing register; and

one or more further registers; wherein

said register write circuit acts such that a fixed relative number of bits within said data processing register and said one or more further registers as a whole transition from high to low and from low to high irrespective of what data value is being written to data processing register and what data value was previously stored within said data processing register.

2. Apparatus as claimed in claim 1, wherein when said register writing circuit writes a value  $X_i$  to an  $i^{th}$  bit of said data processing register previously storing a value of  $Y_i$ , said register writing circuit also writes to corresponding bit positions within three further registers respective values of:

an inverse of X<sub>i</sub>;

a new value  $Rd_i$  given by (inverse  $(X_i XOR Y_i)$ ) XOR (a value of  $Rd_i$  currently stored)); and

an inverse said new value of Rdi.

- 3. Apparatus as claimed in any one of claims 1 and 2, wherein said data processing register is one of a plurality of data processing registers of a register bank.
- 4. Apparatus as claimed in claim 3, wherein said three further registers comprise a dedicated dummy register dedicated to said data processing register and two shared dummy registers shared between said plurality of data processing registers of said register bank.
- 5. Apparatus as claimed in claim 4, wherein said dedicated dummy register stores said inverse of  $X_i$  and said two shared dummy registers store said exclusive logical OR of  $X_i$  with  $Y_i$  and said inverse of the exclusive logical OR of  $X_i$  with  $Y_i$ .



- 6. Apparatus as claimed in any one of claims 3, 4 and 5, wherein said three further registers are provided for a subset of said plurality of data processing registers of said register bank.
- 7. A method of processing data, said method comprising the steps of:
  storing a data value in a data processing register; and
  storing a data value with one or more further registers such than a fixed
  relative number of bits within said data processing register and said one or more
  further registers as a whole transition from high to low and from low to high
  irrespective of what data value is being written to data processing register and what
  data value was previously stored within said data processing register.
- 8. A method as claimed in claim 7, wherein when writing a value  $X_i$  to an  $i^{th}$  bit of said data processing register previously storing a value of  $Y_i$ , also writing to corresponding bit positions within three further registers respective values of: an inverse of  $X_i$ ; a new value  $Rd_i$  given by (inverse  $(X_i XOR Y_i)$ ) XOR (a value of  $Rd_i$  currently stored)); and an inverse said new value of  $Rd_i$ .
- 9. A method as claimed in any one of claims 7 and 8, wherein said data processing register is one of a plurality of data processing registers of a register bank.
- 10. A method as claimed in claim 9, wherein said three further registers comprise a dedicated dummy register dedicated to said data processing register and two shared dummy registers shared between said plurality of data processing registers of said register bank.
- 11. A method as claimed in claim 10, wherein said dedicated dummy register stores said inverse of  $X_i$  and said two shared dummy registers store said exclusive logical OR of  $X_i$  with  $Y_i$  and said inverse of the exclusive logical OR of  $X_i$  with  $Y_i$ .



12. A method as claimed in any one of claims 9, 10 and 11, wherein said three further registers are provided for a subset of said plurality of data processing registers